//axios的封装处理
import axios from "axios";
import { getToken } from "./token";
//1。根域名
//2。超时时间
//3.请求拦截器/响应 拦截器

const request = axios.create({
  baseURL: 'http://localhost:9090',
  timeout: 5000
})

// 添加请求拦截器
//在请求发送之前 做拦截 插入一些自定义的配置-参数处理
request.interceptors.request.use((config) => {
  //操作这个config，注入token数据
  //1、获取到token
  //2、按照后端的格式要求做token数据
  const token = getToken()
  if (token) {
    config.headers.token = `${token}`
  }

  return config
}, (error) => {
  return Promise.reject(error)
})

// 添加响应拦截器
//在响应返回到客户端之前 做拦截 重点处理返回的
request.interceptors.response.use((response) => {
  // 2xx 范围内的状态码都会触发该函数。
  // 对响应数据做点什么
  //console.log(response.data)
  return response.data

}, (error) => {

  // 超出 2xx 范围的状态码都会触发该函数。
  // 对响应错误做点什么
  return Promise.reject(error)
})

export { request }